#s4-titlerow-custom {
  display: none !important;
}
body {
  font-family: 'Fira Sans', sans-serif;
  font-family: 'Inter', sans-serif;
}

h1, h2, h3, h4, h5, h6, p, ul {
  margin: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Fira Sans', sans-serif;
}

p, ul {
  font-family: 'Inter', sans-serif;
}

.vacancy-info {
  max-width: 860px;
  margin-bottom: 60px;
}

.vacancy-info-item__title {
  font-size: 36px;
  font-weight: 700;
  line-height: 130%;
  color: #020F12;
  margin-bottom: 20px;
}

.vacancy-info-item {
  margin-bottom: 50px;
}

.vacancy-info-item__descr, .vacancy-info-list__item {
  font-size: 16px;
  font-weight: 400;
  line-height: 150%;
  color: #020F12;
}

.vacancy-info-item .vacancy-info-item__descr:not(:last-child) {
  margin-bottom: 12px;
}

.vacancy-info-list {
  padding-left: 20px;
}

.vacancy-info-list__item:not(:last-child) {
  margin-bottom: 4px;
}

.vacancy-button {
  height: 66px;
  font-family: 'Inter', sans-serif;
  padding: 0 26px;
  border-radius: 10px;
  font-size: 24px;
  font-weight: 700;
  line-height: 110%;
  color: #ffffff;
  border: none;
  outline: none;
  cursor: pointer;
  transition: all 0.2s;
  margin: 0;
}

.vacancy-header {
  margin-bottom: 120px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 30px;
}

.vacancy-header-info-heading {
  font-size: 94px;
  font-weight: 700;
  line-height: 110%;
}

.vacancy-header-info__name {
  font-size: 52px;
  font-weight: 700;
  line-height: 110%;
  color: #020F12;
  margin-bottom: 20px;
}

.vacancy-status {
  margin-bottom: 20px;
  height: 51px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  border: 3px solid currentColor;
  border-radius: 80px;
  padding: 0 28px;
  font-size: 28px;
  font-weight: 700;
  line-height: 110%;
  font-family: 'Fira Sans', sans-serif;
}

.vacancy-card__department {
  font-size: 24px;
  font-weight: 600;
  line-height: 130%;
  color: #020F12;
  margin-bottom: 6px;
}

.vacancy-header__button {
  margin-top: 32px;
}

.vacancy-card__address {
  font-family: 'Fira Sans', sans-serif;
  font-size: 18px;
  font-weight: 400;
  color: #020F12;
}

.vacancy-info-wrapper {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.vacancy-page {
  max-width: 1280px;
  margin: 0 auto;
}

.long-line-path path {
  stroke-width: 7;
  stroke-dasharray: 2536;
  stroke-dashoffset: 2536;
  animation: draw 4s linear forwards;
}

@keyframes draw {
  100% {
      stroke-dashoffset: 0;
  }
}

.vacancy-header-picture {
  width: 580px;
  height: 420px;
  border-radius: 20px;
  flex-shrink: 0;
}

.rocket {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

  .rocket img {
      max-width: 580px;
      border-radius: 20px;
  }

.rocket-svg {
  margin-left: auto;
  margin-right: 92px;
}

.rocket-short-line {
  transform: translateY(-70px);
}

  .rocket-long-line path, .rocket-short-line path, .right-wing-path, .left-wing-path, .rocket-tail-path, .rocket-body-path, .rocket-window-path, .rocket-line-path {
      stroke: #FFFFFF;
      stroke-width: 7;
  }

.rocket-long-line path {
  stroke-dasharray: 717;
  stroke-dashoffset: 717;
  animation: draw 2s linear forwards;
}

.rocket-short-line path {
  stroke-dasharray: 185;
  stroke-dashoffset: 185;
  animation: draw 1s linear forwards;
}

.right-wing-path, .left-wing-path {
  stroke-dasharray: 203;
  stroke-dashoffset: 203;
  animation: draw 1s linear forwards;
}

.rocket-tail-path {
  stroke-dasharray: 140;
  stroke-dashoffset: 140;
  animation: draw 0.5s linear forwards;
}

.rocket-body-path {
  stroke-dasharray: 613;
  stroke-dashoffset: 613;
  animation: draw 1s linear forwards;
}

.rocket-window-path {
  stroke-dasharray: 159;
  stroke-dashoffset: 159;
  animation: draw 1s linear forwards;
}

.rocket-line-path {
  stroke-dasharray: 118;
  stroke-dashoffset: 118;
  animation: draw 0.5s linear forwards;
}

@media screen and (min-width: 320px) and (max-width: 1200px) {
  .vacancy-header {
      flex-direction: column;
      justify-content: flex-start;
      margin-bottom: 70px;
  }
}

@media screen and (min-width: 320px) and (max-width: 1400px) {
  .long-line-path {
      display: none;
  }
}


@media screen and (min-width: 320px) and (max-width: 767px) {
  .vacancy-header-picture {
      max-width: 100%;
      height: 210px;
  }

  .vacancy-header {
      margin-bottom: 70px;
  }

  .vacancy-header-info-heading {
      font-size: 50px;
  }

  .vacancy-header-info__name {
      font-size: 24px;
  }

  .vacancy-status {
      margin-bottom: 20px;
      height: 41px;
      padding: 0 22px;
      font-size: 18px;
  }

  .vacancy-card__department {
      font-size: 18px;
      margin-bottom: 4px;
  }

  .vacancy-header__button {
      margin-top: 20px;
  }

  .vacancy-button {
      height: 52px;
      font-size: 18px;
  }

  .rocket-svg {
      width: 145px;
      height: 145px;
      margin-left: 0;
      margin-right: 0;
  }

  .rocket-long-line {
      width: 145px;
      transform: translate(-20px, -20px);
  }

  .rocket-short-line {
      width: 45px;
  }

  .vacancy-info-item__title {
      font-size: 24px;
      margin-bottom: 12px;
  }

  .vacancy-info-item__descr {
      font-size: 14px;
  }

  .vacancy-info-item {
      margin-bottom: 30px;
  }

  .vacancy-info-list__item {
      font-size: 14px;
  }
}


#internship-display-form.primary .vacancy-status {
  color: #07B6F0 !important;
}

#internship-display-form.primary .long-line-path path {
  stroke: #05BAF6 !important;
}

#internship-display-form.primary .vacancy-button {
  background: #05BAF6 !important;
}

#internship-display-form.primary .vacancy-button:hover {
  background: #0AACE2 !important;
}

#internship-display-form.primary .vacancy-header-info-heading {
  color: #07B6F0 !important;
}

#internship-display-form.primary .vacancy-header-picture {
  background: #07B6F0 !important;
}

#internship-display-form.primary .vacancy-header-info-heading--primary {
  color: #07B6F0 !important;
}

#internship-display-form.secondary .vacancy-status {
  color: #F39224 !important;
}

#internship-display-form.secondary .long-line-path path {
  stroke: #F39224 !important;
}

#internship-display-form.secondary .vacancy-button {
  background: #F39224 !important;
}

#internship-display-form.secondary .vacancy-button:hover {
  background: #FF9B29 !important;
}

#internship-display-form.secondary .vacancy-header-info-heading {
  color: #F39224 !important;
}

#internship-display-form.secondary .vacancy-header-picture {
  background: #F39224 !important;
}

#internship-display-form.secondary .vacancy-header-info-heading--primary {
  color: #F39224 !important;
}


ul li:not(:last-child), ol li:not(:last-child) {
  margin-bottom: 12px;
}

.vacancy-info-item div * {
  font-size: 18px;
  line-height: 150%;
}

@media screen and (min-width: 320px) and (max-width: 767px) {
  .rocket img {
    max-width: 100%;
    border-radius: 15px;
    margin-bottom: 30px;
  }
}